### Digitaltechnik Labor 4

# Parkplatzzähler: Endlich endliche Automaten

### Vorbereitung

Jan Hoegen\*

Erstellt am: 1. Mai 2022

Betreuer: Prof. Dr. -Ing. Jan Bauer

#### Inhaltsverzeichnis

| 1 | Analyse der Parkplatzschaftung        | Z |
|---|---------------------------------------|---|
| 2 | Analyse des endlichen Automaten       | 2 |
| 3 | Auswahl der Zustandscodierung         | 2 |
| 4 | Aufbau der Zustandsübergangstabelle   | 2 |
| 5 | Auswahl des Standardbausteins         | 4 |
| 6 | Realisierung des Übergangschaltnetzes | 4 |
| 7 | Realisierung des Ausgangsschaltnetzes | 4 |
| 8 | Vereinfachen der Full-NAND-Lösung     | 5 |
| 9 | Simulation der Schaltung              | 6 |

<sup>\*</sup>Matrikelnumer: 82358

#### 1 Analyse der Parkplatzschaltung

Die Widerstände an den Tastern Count down und Count up sorgen dafür, dass zu jeder Zeit eine Spannung kleiner als  $V_{CC}$  an den Eingängen UP und DOWN des 74HC192 anliegt. Wird der Taster betätigt, so wird der entsprechende Eingang zwecklos geschalten und die Spannung  $V_{CC}$  fällt vollständig am Widerstand ab. In diesem Fall liegt keine Spannung mehr am Eingang an.

Die beiden 74HC4511 sind ein BCD-zu-7-Segment-Codewandler. Abhängig der Eingangsvariablen A bis D werden die Ausgänge a bis g auf HIGH bzw. LOW gesetzt, sodass die 7 Segmente der Anzeige eine Dezimalzahl 0 bis 9 anzeigen. Dabei beschreibt das Datenblatt eine feste Codiertabelle, in der jedem Eingangszustand eine Ziffer zugeordnet wird.

Der 74HC192 addiert jedes Mal, wenn der UP-Eingang eine positive Taktflanke aufweist, zu seinem Aktuellen Zustand die Binärzahl 0001 dazu und speichert das Ergebnis als seinen neuen Zustand. Ähnlich verhält es sich mit dem DOWN-Eingang, jedoch wird hier mit der Binärzahl 0001 subtrahiert. Dabei können die Ausgangsvariablen  $Q_0$  bis  $Q_3$  Binärzahlen von 0000 bis 1001 anzeigen. Dies entspricht den Dezimalzahlen 0 bis 9.¹ Führt das Ergebnis der beiden Summanden zu einer Zahl, die größer als dieser Zahlenbereich ist, so wird der Carry-Ausgang auf HIGH gesetzt und die Ausgänge  $Q_0$  bis  $Q_3$  auf LOW. Erzeugt die Rechnung jedoch einen Underflow, so wird borrow auf HIGH gesetzt.

Auf die übrigen Pins des IC wird an dieser Stelle nicht näher eingegangen.

Der erste 74HC192 führt diese Funktion genau dann aus, wenn der Taster Count up bzw. Count down nach vorherigem Drücken wieder losgelassen wird. Der zweite 74HC192 erhält sein Eingangssignal UP, wenn das Ergebnis des Ersten größer als 1001 ist, bzw für den Eingang DOWN bei einem Underflow.

#### 2 Analyse des endlichen Automaten

Das Zustandsdiagramm zeigt einen Moore-Automaten. Denn die Ausgangsvariablen sind lediglich vom Speicherzustand abhängig, nicht auf direkte Weise mit den Eingangsvariablen. Es werden zwei D-Flip-Flops benötigt, um die Zustände zu realisieren.

### 3 Auswahl der Zustandscodierung

Da das Ergebnis der Aufgabe 0 der dritten Laborvorbereitung  $P_T=0$  lautete, ist die Zustandscodierung aus Tabelle 1 zu verwenden.

### 4 Aufbau der Zustandsübergangstabelle

Nun wird die Zustandsübergangstabelle in Tabelle 2 vervollständigt.

<sup>&</sup>lt;sup>1</sup>Der BCD-Codewandler ist ebenfalls für die Zahlen 0 bis 9 definiert, also den Binärzahlen 0000 bis 1001.

Tabelle 1: Zustandscodierung der FSM

| Zustand | $Q_1$ | $Q_0$ |
|---------|-------|-------|
| idle    | 0     | 0     |
| forw    | O     | 1     |
| back    | 1     | 0     |
| wait    | 1     | 1     |

Tabelle 2: Zustandsübergangstabelle

|      |                                       |       | n     |       |       | n+1   |       |
|------|---------------------------------------|-------|-------|-------|-------|-------|-------|
| Nr.  | Übergang                              | $S_2$ | $S_1$ | $Q_1$ | $Q_0$ | $Q_1$ | $Q_0$ |
| 1    | $idle \to idle$                       | 0     | 0     | 0     | 0     | 0     | 0     |
| 2 .  | forw-s korw                           | 0     | 0     | 0     | 1     | 0     | ٦     |
| 3    | bach -> bach                          | 0     | 0     | 1     | 0     | 4     | 9     |
| 4    | wait $\rightarrow$ idle               | 0     | 0     | 1     | 1     | 0     | 2     |
| 5    | $idle \to forw$                       | 0     | 1     | 0     | 0     | 0     | 7     |
| 6    | form-sorm                             | 0     | 1     | 0     | 1     | 0     | 7     |
| 7    | back -7 V                             | 0     | 1     | 1     | 0     | X     | X     |
| 8    | $wait \rightarrow wait$               | 0     | 1     | 1     | 1     | 1     | 1     |
| 9    | $idle \to back$                       | 1     | 0     | 0     | 0     | 1     | Š     |
| 10   | form-> &                              | 1     | 0     | 0     | 1     | X     |       |
| 11   | back -> back                          | 1     | 0     | 1     | 0     | 1     | 0     |
| 12   | $wait \rightarrow wait$               | 1     | 0     | 1     | 1     | 1     | 1     |
| 13   | $idle \to X$                          | 1     | 1     | 0     | 0     | X     | X     |
| 14 8 | forw-Twait                            | 1     | 1     | 0     | 1     | 1     | 1     |
| 15   | hack-swait                            | 1     | 1     | 1     | 0     | 1     | 1     |
| 16   | $\text{wait} \rightarrow \text{wait}$ | 1     | 1     | 1     | 1     | 1     | 1     |

#### 5 Auswahl des Standardbausteins

Da das Ergebnis der Aufgabe 0 der dritten Laborvorbereitung  $P_M=0$  lautete, ist das ASN und das ÜSN in Full-NAND zu realisieren.

#### 6 Realisierung des Übergangschaltnetzes

Das Übergangsschaltnetz wird mit Hilfe der Tabelle 2 in Full-NAND erstellt. Es gilt  $Q_0 = D_0$  und  $Q_1 = D_1$ .

Tabelle 3: KV-Tafel für  $D_0$ Tabelle 4: KV-Tafel für  $D_1$ O Sasa O X X X  $\bigcirc$ 

Für  $D_0$  erhält man nach Umformen der disjunktiven Minimalform in Full-NAND:

$$D_0 = S_1 \vee (Q_0 \wedge \overline{Q_1}) \vee (S_2 \wedge Q_0)$$

$$= \overline{S_1} \wedge \overline{(Q_0 \wedge \overline{Q_1})} \wedge \overline{(S_2 \wedge Q_0)}$$

Gleiches Vorgehen für  $D_1$ :

$$D_1 = S_2 \vee (\overline{Q_0} \wedge Q_1) \vee (S_1 \wedge Q_1)$$

$$= \overline{S_2} \wedge \overline{(\overline{Q_0} \wedge Q_1)} \wedge \overline{(S_1 \wedge Q_1)}$$

### 7 Realisierung des Ausgangsschaltnetzes

Als Nächstes wird das Ausgangsschaltnetz in Full-NAND dargestellt. Dabei wird die Wahrheitstabelle in 5 aufgestellt.

Tabelle 5: Wahrheitstabelle des ASN

| $Q_1$ | $Q_0$ | Dn | Up |
|-------|-------|----|----|
| 0     | 0     | 1  | 1  |
| 0     | 1     | 1  | 0  |
| 1     | 0     | 0  | 1  |
| 1     | 1     | 1  | 1  |

Tabelle 6: KV-Tafel für Up



Tabelle 7: KV-Tafel für *Dn* 



Schließlich werden auch die DMF von UP und DN durch Full-NAND realisiert.

$$Up = \overline{Q_0} \vee Q_1$$

$$UP = \overline{Q_0} \wedge \overline{Q_1}$$

$$Dn = Q_0 \vee \overline{Q_1}$$

$$Dn = \overline{\overline{Q_0}} \wedge Q_1$$

# 8 Vereinfachen der Full-NAND-Lösung

Die Terme  $\overline{\overline{Q_0} \wedge Q_1}$  und  $\overline{Q_0 \wedge \overline{Q_1}}$  des ASN kommen bereits im Übergangsschaltnetz vor. Daher können hier zwei Gatter eingespart werden. Es sind somit insgesamt 12 NAND-Gatter



Abbildung 1: Simulation der Schaltung

notwendig.

## 9 Simulation der Schaltung

Die aufgebaute Schaltung ist Abbildung 1 zu entnehmen. Die Auswertung der Schaltung erzeugt die Wahrheitstabelle 8. Sie stimmt mit Tabelle 2 und dem Zustandsdiagramm überein. Es wurde also ein korrektes Schaltungssdesign verwendet. Außerdem wurde die Anforderung an maximal 12 NAND-Gatter erfüllt.

Tabelle 8: Wahrheitstabelle der simulierten Schaltung

| $S_2$ | $S_1$ | $Q_1$ | $Q_0$ | Dn | Up |
|-------|-------|-------|-------|----|----|
| 0     | 0     | 0     | 0     | 1  | 1  |
| 0     | 1     | 0     | 0     | 1  | 0  |
| 0     | 1     | 0     | 1     | 1  | 0  |
| 0     | 0     | 0     | 1     | 1  | 0  |
| 1     | 1     | 0     | 1     | 1  | 1  |
| 1     | 1     | 1     | 1     | 1  | 1  |
| 1     | 0     | 1     | 1     | 1  | 1  |
| 0     | 1     | 1     | 1     | 1  | 1  |
| 0     | 0     | 1     | 1     | 1  | 1  |
| 0     | 0     | 0     | 0     | 1  | 1  |
| 1     | 0     | 0     | 0     | 0  | 1  |
| 1     | 0     | 1     | 0     | 0  | 1  |
| 0     | 0     | 1     | 0     | 0  | 1  |
| 1     | 1     | 1     | 0     | 1  | 1  |
| 1     | 1     | 1     | 1     | 1  | 1  |
| 0     | 1     | 1     | 1     | 1  | 1  |
| 0     | 1     | 1     | 0     | 1  | 1  |
| 0     | 0     | 1     | 1     | 1  | 1  |
|       |       |       |       |    |    |